# Programmers Model

## Transitions for Way Group State

Each waygroup can exist in one of three states. It can be enabled for Cache, enabled for RAM, or disabled. When disabled, it may be powered off. This section will describe the transitions between these states.

![](data:image/x-emf;base64,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NgAAABAAAAB1CQAAOQsAAFgAAAA0AAAAAAAAAAAAAAD//////////wYAAAB1CTYLdwkzC3oJMgt9CTALgAkxC4MJMwtZAAAAMAAAAAAAAAAAAAAA//////////8FAAAAQArcCzQK3Au2DA8JtwwaCfoLcQhYAAAANAAAAAAAAAAAAAAA//////////8GAAAA9wtvCPYLawj4C2gI+QtlCPsLYwj/C2MINgAAABAAAAAdDgAARQgAAFgAAAAoAAAAAAAAAAAAAAD//////////wMAAAAhDkUIJQ5ICCUOTAg2AAAAEAAAAEQOAABrCgAAWAAAADQAAAAAAAAAAAAAAP//////////BgAAAEQObgpCDnEKPw5yCjwOdAo5DnMKNg5xClkAAAAwAAAAAAAAAAAAAAD//////////wUAAAB5DcgJhQ3HCQMLlQwCC4oMvwszDVgAAAA0AAAAAAAAAAAAAAD//////////wYAAADCCzUNwgs4DcELOw3ACz4NvQtADboLQQ02AAAAEAAAAJwJAABfDQAAWAAAADQAAAAAAAAAAAAAAP//////////BgAAAJgJXw2UCVwNlAlXDZMJUw2XCU8NmwlPDVkAAAAoAAAAAAAAAAAAAAD//////////wMAAAC5CzENtAs/DfgKlgxYAAAAKAAAAAAAAAAAAAAA//////////8DAAAA9AqTDPQKjgz3CooMNgAAABAAAAB5DQAAvQkAAFgAAAAoAAAAAAAAAAAAAAD//////////wMAAAB8DbkJgQ25CYQNvAlZAAAAOAAAAAAAAAAAAAAA//////////8HAAAAQQ5lCjQOawoVDk0IHg5VCAAMcwgEDGUIwQwOCVgAAAAoAAAAAAAAAAAAAAD//////////wMAAADFDBEJxQwWCcIMGQk2AAAAEAAAAEAKAADnCwAAWAAAACgAAAAAAAAAAAAAAP//////////AwAAAD0K6gs4CusLNQroC1kAAAAoAAAAAAAAAAAAAAD//////////wMAAAB4CT8LhQk4C6QJVg1YAAAANAAAAAAAAAAAAAAA//////////8GAAAApAlbDaAJXw2cCV8NmAlfDZQJXA2UCVcNPQAAAAgAAAA8AAAACAAAAD4AAAAYAAAAlwAAAIQAAADkAAAA1gAAABMAAAAMAAAAAQAAACUAAAAMAAAA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eIiIiImZmZmaqqq7u7u7zMzd3e7u4iIjNEVVVmZnd3d3d4iIiIiZmZmZqqqru7u7vMzN3d7u7iJ3iIiIiJmZmZmqqru7u7u8zM3d3u7iIiIzRFVVZmZ3d3d3eIiIiImZmZmaqqq7u7u7zMzd3e7u4neIiIiIiZmZmZqqq7u7u7vMzN3d7u4iIiM0RVVWZmd3d3d4iIiIiJmZmZmqqru7u7u8zM3d3u7id3iIiIiImZmZmaqqu7u7u7zMzd3e7uIiIzNEVVVmZnd3d3eIiIiIiZmZmZqqq7u7u7vMzN3d7u53d4iIiIiJmZmZmqqru7u7u8zM3d3u7iIiM0RFVVZmZ3d3d3iIiIiImZmZmaqqu7u7u7zMzd3e7nd3eIiIiImZmZmZqqq7u7u7zMzN3d7u4iIjNEVVVWZmd3d3d4iIiIiJmZmZmqqru7u7u8zM3d3ud3d3iIiIiJmZmZmaqqu7u7u8zMzd3e7uIiIzRFVVZmZnd3d3eIiIiImZmZmZqqq7u7u7zMzN3d53d3d4iIiIiZmZmZmqqru7u7vMzN3d3u7iIiM0RVVWZmZ3d3d3iIiIiJmZmZmaqqu7u7u8zM3d3Xd3d3eIiIiImZmZmZqqq7u7u7zMzd3d7u4iIjNEVVVmZnd3d3d4iIiIiZmZmZmqqru7u7vMzN3dd3d3d3iIiIiJmZmZmqqqu7u7u8zM3d3u7uIiIzRFVVZmZ3d3d3eIiIiImZmZmZqqq7u7u7zMzd1nd3d3d4iIiIiZmZmZqqqru7u7vMzN3d7u4iIiM0RVVWZmd3d3d3iIiIiJmZmZmqqqu7u7u8zM3WZ3d3d3iIiIiImZmZmaqqu7u7u7zMzd3e7uIiIjNEVVVmZnd3d3d4iIiIiZmZmZqqq7u7u7vMzNZmd3d3d4iIiIiJmZmZmqqru7u7u8zM3d3u7iIiMzRFVVZmZ3d3d3iIiIiImZmZmaqqu7u7u7zMxmZnd3d3eIiIiIiZmZmZqqq7u7u7vMzN3d7u4iIjNERVVWZmd3d3d4iIiIiJmZmZmqqru7u7u8zFZmZ3d3d3iIiIiImZmZmaqqu7u7u8zMzd3e7uIiIzRFVVVmZnd3d3eIiIiIiZmZmZqqq7u7u7vMVmZmd3d3d4iIiIiZmZmZmqqru7u7vMzM3d3u7iIiM0RVVVZmZ3d3d3iIiIiJmZmZmaqqu7u7u8xVZmZnd3d3eIiIiImZmZmZqqq7u7u7zMzd3d7u4iIjNEVVVmZmd3d3d4iIiIiZmZmZmqqru7u7vFVWZmd3d3d3iIiIiJmZmZmaqqu7u7u8zM3d3e7uIiIzRFVVZmZnd3d3eIiIiImZmZmZqqq7u7u7VVVmZnd3d3d4iIiIiZmZmZqqqru7u7vMzN3d7u7iIiM0RVVWZmd3d3d3iIiIiJmZmZmaqqu7u7tFVVZmZ3d3d3eIiIiImZmZmaqqq7u7u7zMzd3e7u4iIjNEVVVmZnd3d3d4iIiIiZmZmZqqqru7u0RVVWZmd3d3d3iIiIiJmZmZmqqru7u7u8zM3d3u7iIiIzRFVVZmZ3d3d3eIiIiImZmZmaqqq7u7NEVVVmZnd3d3eIiIiIiZmZmZqqq7u7u7vMzN3d7u4iIiM0RVVWZmd3d3d4iIiIiJmZmZmqqru7s0RFVVZmZ3d3d3iIiIiImZmZmaqqu7u7u7zMzd3e7uIiIzNEVVVmZnd3d3eIiIiIiZmZmZqqq7uzNEVVVWZmd3d3d4iIiIiJmZmZmqqru7u7u8zM3d3u7iIiM0RVVVZmZ3d3d3iIiIiImZmZmaqqu7IzRFVVVmZnd3d3eIiIiImZmZmZqqq7u7u7zMzN3d7u4iIjNEVVVWZmd3d3d4iIiIiJmZmZmqqrsiM0RVVWZmZ3d3d3iIiIiJmZmZmaqqu7u7u8zMzd3e7uIiIzRFVVZmZnd3d3eIiIiImZmZmZqqqyIjNEVVVmZnd3d3d4iIiIiZmZmZmqqru7u7vMzN3d3u7iIiM0RVVWZmZ3d3d3iIiIiJmZmZmaqqIiIzRFVVZmZ3d3d3eIiIiImZmZmZqqq7u7u7zMzd3e7u4iIjNEVVVmZnd3d3d4iIiIiZmZmZmqriIiM0RVVWZmd3d3d3iIiIiJmZmZmqqqu7u7u8zM3d3u7uIiIzRFVVZmZ3d3d3eIiIiImZmZmaquIiIjNEVVVmZnd3d3d4iIiIiZmZmZqqqru7u7vMzN3d7u4iIiM0RVVWZmd3d3d3iIiIiJmZmZmq7iIiMzRFVVZmZ3d3d3iIiIiImZmZmaqqu7u7u7zMzd3e7uIiIjNEVVVmZnd3d3d4iIiIiZmZmZru4iIjNERVVWZmd3d3d4iIiIiJmZmZmqqru7u7u8zM3d3u7iIiMzRFVVZmZ3d3d3iIiIiImZmZme7uIiIzRFVVVmZnd3d3eIiIiIiZmZmZqqq7u7u7vMzN3d7u4iIjNERVVWZmd3d3d4iIiIiJmZmZ3u7iIiM0RVVVZmZ3d3d3iIiIiImZmZmaqqu7u7u8zMzd3e7uIiIzRFVVVmZnd3d3eIiIiIiZmZnd7u4iIjNEVVVmZmd3d3d4iIiIiZmZmZmqqru7u7vMzM3d3u7iIiM0RVVVZmZ3d3d3iIiIiJmZmd3e7uIiIzRFVVZmZnd3d3eIiIiImZmZmZqqq7u7u7zMzd3d7u4iIjNEVVVmZmd3d3d4iIiIiZmZ3d7u7iIiM0RVVWZmd3d3d3iIiIiJmZmZmaqqu7u7u8zM3d3e7uIiIzRFVVZmZnd3d3eIiIiImZnd3e7u4iIjNEVVVmZnd3d3d4iIiIiZmZmZqqqru7u7vMzN3d7u7iIiM0RVVWZmd3d3d3iIiIiJmc3d3u7iIiIzRFVVZmZ3d3d3eIiIiImZmZmaqqq7u7u7zMzd3e7u4iIjNEVVVmZnd3d3d4iIiIiZzN3d7u4iIiM0RVVWZmd3d3d4iIiIiJmZmZmqqru7u7u8zM3d3u7iIiIzRFVVZmZ3d3d3eIiIiInMzd3e7uIiIzNEVVVmZnd3d3eIiIiIiZmZmZqqq7u7u7vMzN3d7u4iIiM0RVVWZmd3d3d4iIiIiMzM3d3u7iIiM0RFVVZmZ3d3d3iIiIiImZmZmaqqu7u7u7zMzd3e7uIiIzREVVVmZnd3d3eIiIiIzMzN3d7u4iIjNEVVVWZmd3d3d4iIiIiJmZmZmqqru7u7u8zM3d3u7iIiM0RVVVZmZ3d3d3iIiIi8zMzd3e7uIiIzRFVVZmZnd3d3eIiIiImZmZmZqqq7u7u7zMzN3d7u4iIjNEVVVWZmd3d3d4iIiLvMzN3d3u7iIiM0RVVWZmZ3d3d3iIiIiJmZmZmaqqu7u7u8zMzd3e7uIiIzRFVVZmZnd3d3eIiIu7zMzd3d7u4iIjNEVVVmZnd3d3d4iIiIiZmZmZmqqru7u7vMzN3d3u7iIiM0RVVWZmZ3d3d3iIi7u8zM3d3u7uIiIzRFVVZmZ3d3d3eIiIiImZmZmZqqq7u7u7zMzd3e7u4iIjNEVVVmZnd3d3d4iLu7vMzN3d7u4iIiM0RVVWZmd3d3d3iIiIiJmZmZmqqqu7u7u8zM3d3u7uIiIzRFVVZmZ3d3d3eIu7u7zMzd3e7uIiIjNEVVVmZnd3d3d4iIiIiZmZmZqqqru7u7vMzN3d7u4iIiM0RVVWZmd3d3d3i7u7u8zM3d3u7iIiMzRFVVZmZ3d3d3iIiIiImZmZmaqqu7u7u7zMzd3e7uIiIjNEVVVmZnd3d3d7u7u7vMzN3d7u4iIjNERVVWZmd3d3d4iIiIiJmZmZmqqru7u7u8zM3d3u7iIiMzRFVVZmZ3d3d3u7u7u8zMzd3e7uIiIzRFVVVmZnd3d3eIiIiIiZmZmZqqq7u7u7vMzN3d7u4iIjNERVVWZmd3d3eru7u7vMzM3d3u7iIiM0RVVVZmZ3d3d3iIiIiImZmZmaqqu7u7u8zMzd3e7uIiIzRFVVVmZnd3d6q7u7u7zMzd3d7u4iIjNEVVVmZmd3d3d4iIiIiZmZmZmqqru7u7vMzM3d3u7iIiM0RVVVZmZ3d3qqu7u7u8zM3d3e7uIiIzRFVVZmZnd3d3eIiIiImZmZmZqqq7u7u7zMzd3d7u4iIjNEVVVmZmd3eqqru7u7vMzN3d7u7iIiM0RVVWZmd3d3d3iIiIiJmZmZmaqqu7u7u8zM3d3e7uIiIzRFVVZmZ3d6qqq7u7u7zMzd3e7u4iIjNEVVVmZnd3d3d4iIiIiZmZmZqqqru7u7vMzN3d7u7iIiM0RVVWZmd3mqqru7u7u8zM3d3u7iIiIzRFVVZmZ3d3d3eIiIiImZmZmaqqq7u7u7zMzd3e7u4iIjNEVVVmZneZqqq7u7u7vMzN3d7u4iIiM0RVVWZmd3d3d4iIiIiJmZmZmqqru7u7u8zM3d3u7iIiIzRFVVZmZ5maqqu7u7u7zMzd3e7uIiIzNEVVVmZnd3d3eIiIiIiZmZmZqqq7u7u7vMzN3d7u4iIjM0RVVWZmmZmqqru7u7u8zM3d3u7iIiM0RFVVZmZ3d3d3iIiIiImZmZmaqqu7u7u7zMzd3e7uIiIzREVVVmaZmZqqq7u7u7zMzN3d7u4iIjNEVVVWZmd3d3d4iIiIiJmZmZmqqru7u7u8zM3d3u7iIiM0RVVVZpmZmaqqu7u7u8zMzd3e7uIiIzRFVVZmZnd3d3eIiIiImZmZmZqqq7u7u7zMzN3d7u4iIjNEVVVWmZmZmqqru7u7vMzN3d3u7iIiM0RVVWZmZ3d3d3iIiIiJmZmZmaqqu7u7u8zM3d3e7uIiIzRFVVaZmZmZqqq7u7u7zMzd3d7u4iIjNEVVVmZnd3d3d4iIiIiZmZmZmqqru7u7vMzN3d3u7iIiM0RVVZmZmZmqqqu7u7u8zM3d3u7uIiIzRFVVZmZ3d3d3eIiIiImZmZmZqqq7u7u7zMzd3e7u4iIjNEVViZmZmZqqqru7u7vMzN3d7u4iIiM0RVVWZmd3d3d3iIiIiJmZmZmqqqu7u7u8zM3d3u7uIiIzRFWImZmZmaqqu7u7u7zMzd3e7uIiIjNEVVVmZnd3d3d4iIiIiZmZmZqqq7u7u7vMzN3d7u4iIiM0RYiJmZmZmqqru7u7u8zM3d3u7iIiMzRFVVZmZ3d3d3iIiIiImZmZmaqqu7u7u7zMzd3e7uIiIjNEiIiZmZmZqqq7u7u7vMzN3d7u4iIjNERVVWZmd3d3d4iIiIiJmZmZmqqru7u7u8zM3d3u7iIiMzSIiImZmZmaqqu7u7u8zMzd3e7uIiIzRFVVVmZnd3d3eIiIiIiZmZmZqqq7u7u7vMzN3d7u4iIjNIiIiZmZmZmqqru7u7vMzM3d3u7iIiM0RVVVZmZ3d3d3iIiIiJmZmZmaqqu7u7u8zMzd3e7uIiIziIiImZmZmZqqq7u7u7zMzd3d7u4iIjNEVVVmZmd3d3d4iIiIiZmZmZmqqru7u7vMzM3d3u7iIiOIiIiJmZmZmaqqu7u7u8zM3d3e7uIiIzRFVVZmZnd3d3eIiIiImZmZmZqqq7u7u7zMzd3d7u4iIoiIiIiZmZmZqqqru7u7vMzN3d7u7iIiM0RVVWZmd3d3d3iIiIiJmZmZmaqqu7u7u8zM3d3e7uIieIiIiImZmZmaqqq7u7u7zMzd3e7u4iIjNEVVVmZnd3d3d4iIiIiZmZmZqqqru7u7vMzN3d7u7iJ3iIiIiJmZmZmqqru7u7u8zM3d3u7iIiIzRFVVZmZ3d3d3eIiIiImZmZmaqqq7u7u7zMzd3e7uIneIiIiIiZmZmZqqq7u7u7vMzN3d7u4iIiM0RVVWZmd3d3d4iIiIiJmZmZmqqru7u7u8zM3d3u7id3iIiIiImZmZmaqqu7u7u7zMzd3e7uIiIzNEVVVmZnd3d3eIiIiIiZmZmZqqq7u7u7vMzN3d7u53d4iIiIiJmZmZmqqru7u7u8zM3d3u7iIiM0RVVVZmZ3d3d3iIiIiImZmZmaqqu7u7u7zMzd3e7nd3eIiIiImZmZmZqqq7u7u7zMzN3d7u4iIjNEVVVWZmd3d3d4iIiIiJmZmZmqqru7u7vMzM3d3ud3d3iIiIiJmZmZmaqqu7u7u8zMzd3e7uIiIzRFVVZmZnd3d3eIiIiImZmZmZqqq7u7u7zMzN3d53d3d4iIiIiZmZmZmqqru7u7vMzN3d3u7iIiM0RVVWZmZ3d3d3iIiIiJmZmZmaqqu7u7u8zM3d3Xd3d3eIiIiImZmZmZqqq7u7u7zMzd3e7u4iIjNEVVVmZnd3d3d4iIiIiZmZmZmqqru7u7vMzN3dd3d3d3iIiIiJmZmZmqqqu7u7u8zM3d3u7uIiIzRFVVZmZ3d3d3eIiIiImZmZmZqqq7u7u7zMzd1nd3d3d4iIiIiZmZmZqqqru7u7vMzN3d7u4iIiM0RVVWZmd3d3d3iIiIiJmZmZmqqqu7u7u8zM3WZ3d3d3iIiIiImZmZmaqqu7u7u7zMzd3e7uIiIjNEVVVmZnd3d3d4iIiIiZmZmZqqq7u7u7vMzNZmd3d3d4iIiIiJmZmZmqqru7u7u8zM3d3u7iIiMzRFVVZmZ3d3d3iIiIiImZmZmaqqu7u7u7zMxmZnd3d3eIiIiIiZmZmZqqq7u7u7vMzN3d7u4iIjNERVVWZmd3d3d4iIiIiJmZmZmqqru7u7u8zFZmZ3d3d3iIiIiImZmZmaqqu7u7u8zMzd3e7uIiIzRFVVVmZnd3d3eIiIiIiZmZmZqqq7u7u7vMVmZmd3d3d4iIiIiZmZmZmqqru7u7vMzM3d3u7iIiM0RVVVZmZ3d3d3iIiIiJmZmZmaqqu7u7u8xVZmZnd3d3eIiIiImZmZmZqqq7u7u7zMzd3d7u4iIjNEVVVmZmd3d3d4iIiIiZmZmZmqqru7u7vFVWZmd3d3d3iIiIiJmZmZmaqqu7u7u8zM3d3e7uIiIzRFVVZmZnd3d3eIiIiImZmZmZqqq7u7u7VVVmZnd3d3d4iIiIiZmZmZqqqru7u7vMzN3d7u7iIiM0RVVWZmd3d3d3iIiIiJmZmZmaqqu7u7tFVVZmZ3d3d3eIiIiImZmZmaqqq7u7u7zMzd3e7u4iIjNEVVVmZnd3d3d4iIiIiZmZmZqqqru7u0RVVWZmd3d3d4iIiIiJmZmZmqqru7u7u8zM3d3u7iIiIzRFVVZmZ3d3d3eIiIiImZmZmaqqq7u7NEVVVmZnd3d3eIiIiIiZmZmZqqq7u7u7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AgAAAAAAAAAkAAAAMAAAAFQAAAAgAAAAAAAAACgAAAAIAAAACAAAAAEAAQAAAAAAIAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA////AKoAAABVAAAAqgAAAFUAAACqAAAAVQAAAKoAAABVAAAAJQAAAAwAAAACAAAAEwAAAAwAAAACAAAAOwAAAAgAAAAbAAAAEAAAAI8WAAAqCAAANgAAABAAAACoGAAAeAgAAFgAAAA0AAAAAAAAAAAAAAD//////////wYAAACsGHkIrhh7CK8YfgiwGIEIrxiFCKwYhwhZAAAAMAAAAAAAAAAAAAAA//////////8FAAAA4RceCeMXEwlgGmkMVRpoDCAb0AtYAAAANAAAAAAAAAAAAAAA//////////8GAAAAIhvOCyYbzgspG88LLBvRCy0b1AstG9gLNgAAABAAAADeGgAA8Q0AAFgAAAAoAAAAAAAAAAAAAAD//////////wMAAADeGvUN2hr4DdUa+A02AAAAEAAAALwYAACqDQAAWAAAADQAAAAAAAAAAAAAAP//////////BgAAALkYqQ22GKcNtRikDbUYoA22GJ0NuBibDVkAAAAwAAAAAAAAAAAAAAD//////////wUAAACDGQQNghkPDQQXuQkQF7oJRBZSClgAAAA0AAAAAAAAAAAAAAD//////////wYAAABCFlQKPhZUCjwWUgo5FlEKNxZNCjgWSgo2AAAAEAAAAIYWAAAxCAAAWAAAADQAAAAAAAAAAAAAAP//////////BgAAAIcWLQiLFikIjxYqCJMWKwiWFi8IlhYzCFkAAAAoAAAAAAAAAAAAAAD//////////wMAAABIFk0KOxZFCgYXrQlYAAAAKAAAAAAAAAAAAAAA//////////8DAAAACherCQ8XrAkRF68JNgAAABAAAACPGQAABQ0AAFgAAAAoAAAAAAAAAAAAAAD//////////wMAAACRGQkNkRkODY0ZEA1ZAAAAOAAAAAAAAAAAAAAA//////////8HAAAAwhioDb4Ymg3YGugNzxrvDR0b1QspG90LXhp0DFgAAAAoAAAAAAAAAAAAAAD//////////wMAAABbGncMVhp2DFMacww2AAAAEAAAANYXAAAcCQAAWAAAACgAAAAAAAAAAAAAAP//////////AwAAANMXGQnUFxQJ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IjMzRERERFVVVVVmZmZnd3iIiZqru7zMzd3e7uIiIiIzM0RERERVVVVVZmCqu7vMzN3d7u4iIiIjMzRERERFVVVVVmZmZmd3iIiZqru7zMzd3e7uIiIiIjMzRERERVVVVVZmYKu7vMzN3d7u4iIiIiMzRERERFVVVVVmZmZmd3eIiJmqu7zMzd3e7uIiIiIjMzRERERFVVVVZmZgu7vMzN3d7u4iIiIiMzNEREREVVVVVmZmZmd3eIiJmqu7vMzN3e7uIiIiIjMzRERERFVVVVVmZmC7u8zN3d7u4iIiIiMzNEREREVVVVVWZmZmd3eIiJmqu7vMzN3d7u4iIiIjMzRERERFVVVVVmZmYLu8zM3d3u7iIiIiMzNEREREVVVVVWZmZmZ3d4iJmqu7vMzN3d7u4iIiIiMzNERERFVVVVVmZmZgu8zM3d3u7iIiIiIzNEREREVVVVVWZmZmZ3d4iImaq7vMzN3d7u4iIiIiMzNEREREVVVVVmZmZmC8zM3d3u7iIiIiIzM0RERERVVVVWZmZmZ3d4iImaq7u8zM3d3u4iIiIiMzNEREREVVVVVWZmZmYLzM3d3u7iIiIiIzM0RERERVVVVVZmZmZ3d4iImaq7u8zM3d3u7iIiIiMzNEREREVVVVVWZmZmZwzMzd3e7uIiIiIzM0RERERVVVVVZmZmZnd3iImaq7u8zM3d3u7iIiIiIzM0REREVVVVVWZmZmZ3DMzd3e7uIiIiIjM0RERERVVVVVZmZmZnd3iIiZqru8zM3d3u7iIiIiIzM0RERERVVVVWZmZmZ3cMzd3e7uIiIiIjMzRERERFVVVVZmZmZnd3iIiZqru7zMzd3e7iIiIiIzM0RERERVVVVVZmZmZndwzd3e7uIiIiIjMzRERERFVVVVVmZmZnd3iIiZqru7zMzd3e7uIiIiIzM0RERERVVVVVZmZmZnd3DN3d7u4iIiIjMzRERERFVVVVVmZmZmd3eIiZqru7zMzd3e7uIiIiIjMzRERERVVVVVZmZmZnd3gN3d7u4iIiIiMzNERERFVVVVVmZmZmd3eIiJmqu7zMzd3e7uIiIiIjMzRERERFVVVVZmZmZnd3iA3d7u4iIiIiMzNEREREVVVVVmZmZmd3eIiJmqu7vMzN3d7uIiIiIjMzRERERFVVVVVmZmZmd3iIDd7u4iIiIiMzNEREREVVVVVWZmZmd3eIiJmqu7vMzN3d7u4iIiIjMzRERERFVVVVVmZmZmd3eIgN3u7iIiIiMzNEREREVVVVVWZmZmZ3d4iJmqu7vMzN3d7u4iIiIiMzNERERFVVVVVmZmZmd3eIiA3u7iIiIiIzM0REREVVVVVWZmZmZ3d4iImaq7u8zN3d7u4iIiIiMzNEREREVVVVVmZmZmd3eIiJDu7iIiIiIzM0RERERVVVVWZmZmZ3d4iImaq7u8zM3d3u4iIiIiMzNEREREVVVVVWZmZmZ3eIiJkO7iIiIiIzM0RERERVVVVVZmZmZ3d4iImaq7u8zM3d3u7iIiIiIzNEREREVVVVVWZmZmZ3d4iImQ7uIiIiIzM0RERERVVVVVZmZmZnd3iImaq7u8zM3d3u7iIiIiIzM0REREVVVVVWZmZmZ3d4iImaDuIiIiIjMzRERERVVVVVZmZmZnd3iIiZqru7zM3d3u7iIiIiIzM0RERERVVVVVZmZmZ3d4iImaoOIiIiIjMzRERERFVVVVZmZmZnd3iIiZqru7zMzd3e7iIiIiIzM0RERERVVVVVZmZmZnd4iImaqwIiIiIjMzRERERFVVVVVmZmZnd3iIiZqru7zMzd3e7uIiIiIjM0RERERVVVVVZmZmZnd3iIiZqrAiIiIjMzRERERFVVVVVmZmZmd3eIiZqru7zMzd3e7uIiIiIjMzRERERVVVVVZmZmZnd3iIiZqrsCIiIiMzNERERFVVVVVmZmZmd3eIiJmqu7vMzd3e7uIiIiIjMzRERERFVVVVVmZmZnd3iIiZqruwIiIiMzNEREREVVVVVmZmZmd3eIiJmqu7vMzN3d7uIiIiIjMzRERERFVVVVVmZmZmd3iIiZqru7AiIiMzNEREREVVVVVWZmZmd3eIiJmqu7vMzN3d7u4iIiIiMzRERERFVVVVVmZmZmd3eIiJmqu7wCIiMzNEREREVVVVVWZmZmZ3d4iImqu7vMzN3d7u4iIiIiMzNERERFVVVVVmZmZmd3eIiJmqu7vAIiIzM0REREVVVVVWZmZmZ3d4iImaq7u8zN3d7u4iIiIiMzNEREREVVVVVWZmZmd3eIiJmqu7vMAiIzM0RERERVVVVWZmZmZ3d4iImaq7u8zM3d3u7iIiIiMzNEREREVVVVVWZmZmZ3eIiJmqu7vMwCIzM0RERERVVVVVZmZmZ3d4iImaq7u8zM3d3u7iIiIiIzNEREREVVVVVWZmZmZ3d4iImaq7vMzAIzM0RERERVVVVVZmZmZnd3iIiaq7u8zM3d3u7iIiIiIzM0RERERVVVVWZmZmZ3d4iImaq7u8zMAjMzRERERVVVVVZmZmZnd3iIiZqru7zM3d3u7iIiIiIzM0RERERVVVVVZmZmZ3d4iImaq7u8zM0DMzRERERFVVVVZmZmZnd3iIiZqru7zMzd3e7uIiIiIzM0RERERVVVVVZmZmZnd3iImaq7u8zM3QMzRERERFVVVVVmZmZnd3iIiZqru7zMzd3e7uIiIiIjM0RERERVVVVVZmZmZnd3iIiZqru8zM3dAzRERERFVVVVVmZmZmd3eIiJqru7zMzd3e7uIiIiIjMzRERERFVVVVZmZmZnd3iIiZqru7zMzd0DNERERFVVVVVmZmZmd3eIiJmqu7vMzd3e7uIiIiIjMzRERERFVVVVVmZmZnd3iIiZqru7zMzd3QNEREREVVVVVmZmZmd3eIiJmqu7vMzN3d7u4iIiIjMzRERERFVVVVVmZmZmd3eIiZqru7zMzd3eBEREREVVVVVWZmZmd3eIiJmqu7vMzN3d7u4iIiIiMzRERERFVVVVVmZmZmd3eIiJmqu7zMzd3e4EREREVVVVVWZmZmZ3d4iImqu7vMzN3d7u4iIiIiMzNEREREVVVVVmZmZmd3eIiJmqu7vMzN3d7gREREVVVVVWZmZmZ3d4iImaq7u8zN3d7u4iIiIiMzNEREREVVVVVWZmZmd3eIiJmqu7vMzN3d7uBERERVVVVWZmZmZ3d4iImaq7u8zM3d3u7iIiIiMzNEREREVVVVVWZmZmZ3d4iJmqu7vMzN3d7u4ERERVVVVVZmZmZnd4iImaq7u8zM3d3u7iIiIiIzM0REREVVVVVWZmZmZ3d4iImaq7vMzN3d7u4gRERVVVVVZmZmZnd3iIiZq7u8zM3d3u7iIiIiIzM0RERERVVVVWZmZmZ3d4iImaq7u8zM3d3u4iBERVVVVVZmZmZnd3iIiZqru7zMzd3u7iIiIiIzM0RERERVVVVVZmZmZ3d4iImaq7u8zM3d3u7iIERFVVVVZmZmZnd3iIiZqru7zMzd3e7uIiIiIzM0RERERVVVVVZmZmZnd3iImaq7u8zM3d3u7iIgRFVVVVVmZmZmd3iIiZqru7zMzd3e7uIiIiIjMzRERERVVVVVZmZmZnd3iIiZqru7zM3d3u7iIiBFVVVVVmZmZmd3eIiJmru7zMzd3e7uIiIiIjMzRERERFVVVVZmZmZnd3iIiZqru7zMzd3e7iIiIFVVVVVmZmZmd3eIiJmqu7vMzN3e7uIiIiIjMzRERERFVVVVVmZmZnd3iIiZqru7zMzd3e7uIiIgVVVVVmZmZmd3eIiJmqu7vMzN3d7u4iIiIjMzRERERFVVVVVmZmZmd3eIiZqru7zMzd3e7uIiIiBVVVVWZmZmZ3eIiJmqu7vMzN3d7u4iIiIiMzNERERFVVVVVmZmZmd3eIiJmqu7vMzd3e7uIiIiIFVVVWZmZmZ3d4iImau7vMzN3d7u4iIiIiMzNEREREVVVVVmZmZmd3eIiJmqu7vMzN3d7uIiIiIgVVVWZmZmZ3d4iImaq7u8zM3d7u4iIiIiMzNEREREVVVVVWZmZmd3eIiJmqu7vMzN3d7u4iIiIiBVVVZmZmZ3d4iImaq7u8zM3d3u7iIiIiMzNEREREVVVVVWZmZmZ3d4iJmqu7vMzN3d7u4iIiIiMFVVZmZmZnd4iImaq7u8zM3d3u7iIiIiIzM0REREVVVVVWZmZmZ3d4iImaq7u8zN3d7u4iIiIiMwVVZmZmZnd3iIiZqru8zM3d3u7iIiIiIzM0RERERVVVVWZmZmZ3d4iImaq7u8zM3d3u4iIiIiMzBVZmZmZnd3iIiZqru7zMzd3u7iIiIiIzM0RERERVVVVVZmZmZ3d4iImaq7u8zM3d3u7iIiIiIzMFVmZmZnd3iIiZqru7zMzd3e7uIiIiIzM0RERERVVVVVZmZmZnd3iIiaq7u8zM3d3u7iIiIiIzMwVmZmZmd3iIiZqru7zMzd3e7uIiIiIjMzRERERVVVVVZmZmZnd3iIiZqru7zM3d3u7iIiIiIzM0BmZmZmd3eIiJmqu7zMzd3e7uIiIiIjMzRERERFVVVVZmZmZnd3iIiZqru7zMzd3e7uIiIiIzM0QGZmZmd3eIiJmqu7vMzN3e7uIiIiIjMzRERERFVVVVVmZmZnd3iIiZqru7zMzd3e7uIiIiIjM0RAZmZmd3eIiJmqu7vMzN3d7u4iIiIjMzRERERFVVVVVmZmZmd3eIiJqru7zMzd3e7uIiIiIjMzREBmZmZ3eIiJmqu7vMzN3d7u4iIiIiMzNERERFVVVVVmZmZmd3eIiJmqu7vMzd3e7uIiIiIjMzREQGZmZ3d4iImaq7vMzN3d7u4iIiIiMzNEREREVVVVVmZmZmd3eIiJmqu7vMzN3d7u4iIiIjMzRERAZmZ3d4iImaq7u8zM3d7u4iIiIiMzNEREREVVVVVWZmZmd3eIiJmqu7vMzN3d7u4iIiIiMzREREBmZ3d4iImaq7u8zM3d3u7iIiIiMzNEREREVVVVVWZmZmZ3d4iImqu7vMzN3d7u4iIiIiMzNEREQGZnd4iImaq7u8zM3d3u7iIiIiIzM0REREVVVVVWZmZmZ3d4iImaq7u8zN3d7u4iIiIiMzNERERAZnd3iIiZqru8zM3d3u7iIiIiIzM0RERERVVVVWZmZmZ3d4iImaq7u8zM3d3u7iIiIiMzNEREREBnd3iIiZqru7zMzd3e7iIiIiIzM0RERERVVVVVZmZmZ3d4iImaq7u8zM3d3u7iIiIiIzNEREREUHd3iIiZqru7zMzd3e7uIiIiIzM0RERERVVVVVZmZmZnd3iIiaq7u8zM3d3u7iIiIiIzM0RERERQd3eIiZqru7zMzd3e7uIiIiIjMzRERERVVVVVZmZmZnd3iIiZqru7zM3d3u7iIiIiIzM0RERERVB3eIiJmqu7zMzd3e7uIiIiIjMzRERERFVVVVZmZmZnd3iIiZqru7zMzd3e7uIiIiIzM0RERERVUHeIiJmqu7vMzN3d7uIiIiIjMzRERERFVVVVVmZmZmd3iIiZqru7zMzd3e7uIiIiIjMzRERERVVQeIiJmqu7vMzN3d7u4iIiIjMzRERERFVVVVVmZmZmd3eIiJmru7zMzd3e7uIiIiIjMzRERERFVVB4iJmqu7vMzN3d7u4iIiIiMzNERERFVVVVVmZmZmd3eIiJmqu7vMzN3e7uIiIiIjMzRERERFVVUIiImaq7vMzN3d7u4iIiIiMzNEREREVVVVVmZmZmd3eIiJmqu7vMzN3d7u4iIiIjMzRERERFVVVQiImaq7u8zM3d3u4iIiIiMzNEREREVVVVVWZmZmZ3eIiJmqu7vMzN3d7u4iIiIiMzNERERFVVVVCImaq7u8zM3d3u7iIiIiMzNEREREVVVVVWZmZmZ3d4iImau7vMzN3d7u4iIiIiMzNEREREVVVVUImaq7u8zM3d3u7iIiIiIzM0REREVVVVVWZmZmZ3d4iImaq7u8zM3d7u4iIiIiMzNEREREVVVVVQiZqru8zM3d3u7iIiIiIzM0RERERVVVVWZmZmZ3d4iImaq7u8zM3d3u7iIiIiMzNEREREVVVVVWCZqru7zMzd3e7iIiIiIzM0RERERVVVVVZmZmZnd4iImaq7u8zM3d3u7iIiIiIzM0REREVVVVVWYJqru7zMzd3e7uIiIiIzM0RERERVVVVVZmZmZnd3iIiZq7u8zM3d3u7iIiIiIzM0RERERVVVVWZgqru7zMzd3e7uIiIiIjMzRERERVVVVVZmZmZnd3iIiZqru7zMzd3u7iIiIiIzM0RERERVVVVVZmCqu7vMzd3e7uIiIiIjMzRERERFVVVVVmZmZnd3iIiZqru7zMzd3e7uIiIiIzM0RERERVVVVVZmYKu7vMzN3d7uIiIiIjMzRERERFVVVVVmZmZmd3iIiZqru7zMzd3e7uIiIiIjMzRERERVVVVVZmZgu7vMzN3d7u4iIiIiMzRERERFVVVVVmZmZmd3eIiJmqu7zMzd3e7uIiIiIjMzRERERFVVVVZmZmC7vMzN3d7u4iIiIiMzNERERFVVVVVmZmZmd3eIiJmqu7vMzN3e7uIiIiIjMzRERERFVVVVVmZmYLu8zN3d7u4iIiIiMzNEREREVVVVVWZmZmd3eIiJmqu7vMzN3d7u4iIiIjMzRERERFVVVVVmZmZgu8zM3d3u4iIiIiMzNEREREVVVVVWZmZmZ3eIiJmqu7vMzN3d7u4iIiIiMzNERERFVVVVVmZmZmC8zM3d3u7iIiIiIzNEREREVVVVVWZmZmZ3d4iImaq7vMzN3d7u4iIiIiMzNEREREVVVVVmZmZmcMzM3d3u7iIiIiIzM0REREVVVVVWZmZmZ3d4iImaq7u8zM3d7u4iIiIiMzNEREREVVVVVWZmZmdwzM3d3u7iIiIiIzM0RERERVVVVVZmZmZ3d4iImaq7u8zM3d3u7iIiIiMzNEREREVVVVVWZmZmZ3DMzd3e7iIiIiIzM0RERERVVVVVZmZmZnd4iImaq7u8zM3d3u7iIiIiIzM0REREVVVVVWZmZmZ3cMzd3e7uIiIiIjM0RERERVVVVVZmZmZnd3iIiZqru8zM3d3u7iIiIiIzM0RERERVVVVWZmZmZ3dwzd3e7uIiIiIjMzRERERVVVVVZmZmZnd3iIiZqru7zMzd3u7iIiIiIzM0RERERVVVVVZmZmZ3d4Dd3e7uIiIiIjMzRERERFVVVVVmZmZnd3iIiZqru7zMzd3e7uIiIiIzM0RERERVVVVVZmZmZnd3gN3d7u4iIiIjMzRERERFVVVVVmZmZmd3iIiZqru7zMzd3e7uIiIiIjMzRERERVVVVVZmZmZnd3iA3d7u4iIiIiMzRERERFVVVVVmZmZmd3eIiJmqu7zMzd3e7uIiIiIjMzRERERFVVVVZmZmZnd3iIDd7u4iIiIiMzNEREREVVVVVmZmZmd3eIiJmqu7vMzN3d7uIiIiIjMzRERERFVVVVVmZmZnd3iIgN7u4iIiIiMzNEREREVVVVVWZmZmd3eIiJmqu7vMzN3d7u4iIiIjMzRERERFVVVVVmZmZmd3eIiA3u7iIiIiMzNEREREVVVVVWZmZmZ3d4iJmqu7vMzN3d7u4iIiIiMzNERERFVVVVVmZmZmd3eIiJDu7iIiIiIzNEREREVVVVVWZmZmZ3d4iImaq7vMzN3d7u4iIiIiMzNEREREVVVVVmZmZmd3eIiJkO7iIiIiIzM0RERERVVVVWZmZmZ3d4iImaq7u8zM3d3u4iIiIiMzNEREREVVVVVWZmZmZ3eIiJmg7iIiIiIzM0RERERVVVVVZmZmZ3d4iImaq7u8zM3d3u7iIiIiMzNEREREVVVVVWZmZmZ3d4iImaDuIiIiIzM0RERERVVVVVZmZmZnd3iImaq7u8zM3d3u7iIiIiIzM0REREVVVVVWZmZmZ3d4iImaoOIiIiIjM0RERERVVVVVZmZmZnd3iIiZqru8zM3d3u7iIiIiIzM0RERERVVVVWZmZmZ3d4iImaqwIiIiIjMzRERERFVVVVZmZmZnd3iIiZqru7zMzd3e7iIiIiIzM0RERERVVVVVZmZmZnd4iImaq7AiIiIjMzRERERFVVVVVmZmZnd3iIiZqru7zMzd3e7uIiIiIzM0RERERVVVVVZmZmZnd3iIiZq7sCIiIjMzRERERFVVVVVmZmZmd3eIiZqru7zMzd3e7uIiIiIjMzRERERVVVVVZmZmZnd3iIiZqruwIiIiMzNERERFVVVVVmZmZmd3eIiJmqu7zMzd3e7uIiIiIjMzRERERFVVVVZmZmZnd3iIiZqru7AiIiMzNEREREVVVVVmZmZmd3eIiJmqu7vMzN3d7uIiIiIjMzRERERFVVVVVmZmZmd3iIiZqru7wCIiMzNEREREVVVVVWZmZmd3eIiJmqu7vMzN3d7u4iIiIjMzRERERFVVVVVmZmZmd3eIiJmru7zAIiMzNEREREVVVVVWZmZmZ3d4iJmqu7vMzN3d7u4iIiIiMzNERERFVVVVVmZmZmd3eIiJmqu7vMAiAAAADAAAAP////9GAAAAkAAAAIQAAABFTUYrK0AAAAwAAAAAAAAACEAJBBgAAAAMAAAAAhDA2wAAAAADAAAQNEAJAAwAAAAAAAAACEABAkAAAAA0AAAAAhDA2wAAAADOAAAAAAAAAKuqqj4CAAAAAgAAAAIAAAACAAAAAAAAAAIQwNsAAAAAfUkf/xVAAAAQAAAABAAAAAEAAAAkAAAAJAAAAAAAgD0AAAAAAAAAAAAAgD0AAAAAAAAAAAIAAABfAAAAOAAAAAQAAAA4AAAAAAAAADgAAAAAAAAAAAABAAUAAAAAAAAAH0l9AAAAAAAAAAAAAAAAACUAAAAMAAAABAAAACUAAAAMAAAABQAAgFYAAABIAAAAYAEAAIAAAACyAQAA3wAAAAsAAABvFhMIiRhhCL0X+Qg7Gk8MBhu4C7ga0Q2eGIMNahnrDOwWlQkhFi0KbxYTCCUAAAAMAAAABwAAgCUAAAAMAAAAAAAAgCQAAAAkAAAAAACAQQAAAAAAAAAAAACAQQAAAAAAAAAAAgAAACgAAAAMAAAABAAAAEwAAABkAAAAAQAAAAEAAABdAgAAYQEAAAEAAAABAAAAXQIAAGEBAAApAKoAAAAAAAAAAAAAAIA/AAAAAAAAAAAAAIA/AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAiAAAADAAAAP////9GAAAAHAAAABAAAABFTUYrAkAAAAwAAAAAAAAADgAAABQAAAAAAAAAEAAAABQAAAA=)

Figure 15: Each WayGroup supports 3 operation states

As seen in this figure, while 3 state exists, the transitions should always go through the Disabled state. Directly changing Cache Enabled to RAM enabled or vice versa is not supported.

### Cache Mode to Disabled Mode Transition

To transition a waygroup or multiple waygroups from cache mode to disabled mode, the first step is to disabled allocation for those waygroups. This will prevent any new lines from being added to the waygroups. This can be achieved by writing to the Global Allocation Way Group Enable register. By marking the appropriate waygroups as zero, no new lines will allocate into that cache.

After allocation is disabled, the lines present in that waygroup must be flushed and invalidate. The flush will write back any dirty data to memory, while the invalidation will prevent any new requests to an address from writing into the cache in that location. The flush engine is controlled by the LLC Way Flush register. The waygroups that you want to flush can be written to the wayflush register, and it will trigger the flush engine. Once the flush process has completed, the way flush control register will reset to zero. Since the flush sequence can take a significant amount of time, the status can be periodically polled by reading the register to determine if any of the bits are still set. If all are zeroed out, the flush engine has completed.

Once the flush engine has completed, those ways will be guaranteed to be empty and no new lines will be added. During this time, requests will still perform cache lookups for these waygroups, but at this point, they will always miss.

At this point, the Cache Way Enable register can be programmed to indicate that these ways are no longer enabled for Caching. Once they are disabled, new cache accesses will stop reading the cache tags and will ignore the contents of those pins. At this point, the corresponding tag arrays and data arrays can be powered off.

### RAM Mode to Disabled Mode

To transition a waygroup from RAM mode to the Disabled mode, the hardware transition is straightforward. A write to the RAM Way Enable control register can mark the waygroup as disabled.

Software may need more elaborate control sequences. When the waygroup transitions to disabled, the prior content of the RAM is lost. If that data needs to be preserved, a copy sequence must be performed by software to move the data from the RAM to a location in memory. Before this sequence happens, software should coordinate traffic so that new requests to the RAM region are not expected.

### Disabled Mode to Cache Mode

To transition from disabled mode to cache mode, the LLC must go through a sequence where the tag RAMs are invalidated, where they are enabled for use, and then finally they are enabled for allocation.

The first part of this sequence must ensure that the corresponding tag arrays are invalidated. If the ways were previously invalidated and the state was maintained (there was no power sequences, for instance), no further action is required. If the tags are in an unknown state, or have just powered on, an invalidation sequence must occur. The LLC Tag Invalidation Engine control register can be used to initiate an invalidation of the tags for the waygroups in question. The registers can be polled for status to determine when it has completed.

Once invalidated, the cache ways can be enabled for cache mode accesses by writing to the Cache Way Enable register. Once set, those waygroups will be looked up by any cache access. However, the entries will be invalidated until the allocation enables are set up. The allocation controls can be set before the Cache Way Enable register is set because allocation is limited to waygroups that are enabled.

### Disabled Mode to RAM Mode

To transition a disabled waygroup to RAM mode requires three steps. First, the data contents must be overridden. Second, security permissions must be determined for the RAM waygroups, and finally, the waygroups should be set to RAM mode.

The data invalidation must happen in order to ensure that any data that was previously stored into the data array (either cache data or RAM data) is completely invalidated. Without this step, it is possible for the RAM mode to have visibility of unrelated data, including potentially secure data. Invalidation is needed to ensure security is preserved.

Data invalidation happens by writing to the Data Invalidation Engine Control register, indicating which waygroups should be invalidated. This register can also be polled for status.

Once invalidation has completed, but before the RAM mode enable occurs, the security permission must be decided. This can be controlled by writing to the Scratchpad Ram Way Group Security register. This register has one bit per way group, with a value of 1 requiring accesses to be secure, and a value of 0 requiring non-secure.

Finally, the RAM mode can be enabled by setting the Scratchpad RAM Way Group Enable register.

## Register-based Access of RAMs

Both the Data RAMs and Tag RAMs are accessible through register-based accesses. This allows a backdoor method of reading or writing the arrays, which can be useful for debug, DFT follow up, or even for controlling stimulus in a test.

The register-based accesses use two sets of registers. It uses the indirect content registers, and the indirect trigger register. The content registers hold data to be written to the RAMs, or data read from the RAMs. The indirect trigger actually performs the access and indicates RAM address (index and way).

There are 4 kinds of accesses applicable to each of the LLC RAMs. The operations are read, write raw, write+ecc, and read-modify-write.

The read request is triggered by a write to the indirect trigger indicating it should perform a read. It will read the specified RAM location and copy the contents of that RAM into the indirect content registers. The completion of the trigger access occurs only after the RAM access has occurred, so there is no need to poll for completion. Once the trigger access is done, software can load the content registers to view the data in the RAM.

The write request is initiated by a write to the indirect trigger, and it copies the values in the indirect content registers into the RAM. There are two variants of the write request. The first will write the entire array, including ECC, based on the indirect content register. The second variant will write the non-ECC data with the indirect content register but will perform an ECC generation to determine the checkbits to set for the ECC portion of the RAM.

The read-modify-write sequence performs an atomic access to the RAM where it reads the content, XORs the content with the indirect content registers, and writes it back. This allows an atomic method of flipping a specified number of bits. This is useful for forcing the generation of single or double bit errors. The read-modify-write can be triggered during normal operation to introduce single or double bit errors. The operation is atomic, so it will modify the existing content of the RAM without any chance of that entry being modified in the middle of the sequence.

## LLC Allocation Controls

There are several programmable registers that can change the allocation properties of the LLC. These registers correspond to the following NocStudio LLC properties:

* llc\_class\*\_alloc\_waygroups
* llc\_class\_read\_allocate
* llc\_class\_read\_allocate\_use\_arcache
* llc\_class\_write\_allocate
* llc\_class\_write\_allocate\_use\_awcache

The NocStudio properties set the initial values of these registers, but the registers can be reprogrammed at any time to modify the allocation behavior of the system. These registers control which ways an LLC Allocation Class is allowed to allocate into, and whether they should allocate on reads or writes.

These allocation controls are modified by which ways are enabled for cache mode. If a way is disabled for cache mode, programming it to be allocated into will have no effect. This means these properties do not need to be modified as waygroups are enabled or disabled for cache use.

## LLC Host Registers

### LLC\_ALLOC\_ARCACHE\_EN

This register holds one bit for each of the LLC Allocation Classes. If the bit is marked as one, this indicates that read allocation for that LLC Allocation Class is controlled by the ARCACHE bits. If marked as zero, it means the allocation will be controlled by the llc\_alloc\_rd\_en register. The default of this register is configured within NocStudio.

Attribute: RW

Security: Non secure

Bit field description:

* **ARCACHE\_Allocation\_Enable** [7:0] - Read allocation for that LLC Allocation Class is controlled by the ARCACHE bits/llc\_alloc\_rd\_en register.

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 63 | 62 | 61 | 60 | 59 | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 | 50 | 49 | 48 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 | 38 | 37 | 36 | 35 | 34 | 33 | 32 |
| u | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| u | | | | | | | | | | | | | | | | | | | | | | | | ARCACHE\_Allocation\_Enable | | | | | | | |

Table 1 LLC\_ALLOC\_ARCACHE\_EN register

### LLC\_ALLOC\_AWCACHE\_EN

This register holds one bit for each of the LLC Allocation Classes. If the bit is marked as one, this indicates that write allocation for that LLC Allocation Class is controlled by the AWCACHE bits. If marked as zero, it means the allocation will be controlled by the llc\_alloc\_wr\_en register. The default of this register is configured within NocStudio.

Attribute: RW

Security: Non secure

Bit field description:

* **AWCACHE\_Allocation\_Enable** [7:0] - Write allocation for that LLC Allocation Class is controlled by the AWCACHE bits/llc\_alloc\_wr\_en register.

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 63 | 62 | 61 | 60 | 59 | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 | 50 | 49 | 48 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 | 38 | 37 | 36 | 35 | 34 | 33 | 32 |
| u | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| u | | | | | | | | | | | | | | | | | | | | | | | | AWCACHE\_Allocation\_Enable | | | | | | | |

Table 2 LLC\_ALLOC\_AWCACHE\_EN register

### LLC\_ALLOC\_RD\_EN

This register holds one bit for each of the LLC Allocation Classes. The use of this register is controlled by the llc\_alloc\_arcache\_en register, which indicates whether ARCACHE bits should be used for allocation, or whether this register should decide on allocation. If this register is used for an LLC Allocation Class, a value of one will indicate that reads should allocate into the LLC. A value of zero indicates that reads should not allocate.

Attribute: RW

Security: Non secure

Bit field description:

* **Read\_Allocation\_Enable** [7:0] - Reads should/should not allocate into the LLC

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 63 | 62 | 61 | 60 | 59 | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 | 50 | 49 | 48 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 | 38 | 37 | 36 | 35 | 34 | 33 | 32 |
| u | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| u | | | | | | | | | | | | | | | | | | | | | | | | Read\_Allocation\_Enable | | | | | | | |

Table 3 LLC\_ALLOC\_RD\_EN register

### LLC\_ALLOC\_WR\_EN

This register holds one bit for each of the LLC Allocation Classes. The use of this register is controlled by the llc\_alloc\_awcache\_en register, which indicates whether AWCACHE bits should be used for allocation, or whether this register should decide on allocation. If this register is used for an LLC Allocation Class, a value of one will indicate that writes should allocate into the LLC. A value of zero indicates that writes should not allocate.

Attribute: RW

Security: Non secure

Bit field description:

* **Write\_Allocation\_Enable** [7:0] - Writes should/should not allocate into the LLC.

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 63 | 62 | 61 | 60 | 59 | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 | 50 | 49 | 48 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 | 38 | 37 | 36 | 35 | 34 | 33 | 32 |
| u | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| u | | | | | | | | | | | | | | | | | | | | | | | | Write\_Allocation\_Enable | | | | | | | |

Table 4 LLC\_ALLOC\_WR\_EN register

### LLC\_CACHE\_WAY\_ENABLE

This register indicates whether a way is enabled for cache access. If enabled, a cache lookup will read the associated Tag values and perform an address comparison. If disabled, the Tags won't be accessed and the contents of the Tags won't be compared.

This allows the Tags to be powered down or the lines to be used for RAM access. The register has one bit per way, allowing each way to be individually enabled or disabled. A value of 1 indicates that the way is enabled, while a value of 0 indicates it is disabled. All ways are enabled by default. Before disabling a cache way, the way must be disabled in the llc\_global\_alloc register, and the contents should be flushed.

This register requires secure access, since it disables ways of the cache, potentially modifying the contents of secure data.

Attribute: RW

Security: Secure access only

Bit field description:

* **Cache\_Way\_Enable** [31:0] - Cache Way Enable

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 63 | 62 | 61 | 60 | 59 | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 | 50 | 49 | 48 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 | 38 | 37 | 36 | 35 | 34 | 33 | 32 |
| u | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Cache\_Way\_Enable | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |

Table 5 LLC\_CACHE\_WAY\_ENABLE register

### LLC\_CLASS\_ALLOC

The class allocation control registers are used to specify which associative ways can be written to. Each master in the system belongs to an LLC class, and each class allocation control register indicates which ways that class of agents can allocate into.

These registers can be used to provide dedicated associativity for different agents or groups of agents. The default value of these registers indicates that all ways are accessible by all agents, with a value of one indicating allocation is allowed. Setting the value to zero will disable allocation for an agent.

It is permissible to turn off allocation for all ways, which will prevent any accesses from that class from allocating into the cache.

Note that the llc\_global\_alloc register can override these values. If global allocation is disabled for a way, none of the agents can allocate into those ways regardless of what the llc\_class\_allocate registers indicate.

Attribute: RW

Security: Non secure

Bit field description:

* **WGE\_0** [7:0] - Class 0 Allocation Way Enable

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 63 | 62 | 61 | 60 | 59 | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 | 50 | 49 | 48 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 | 38 | 37 | 36 | 35 | 34 | 33 | 32 |
| u | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| u | | | | | | | | | | | | | | | | | | | | | | | | WGE\_0 | | | | | | | |

Table 6 LLC\_CLASS\_ALLOC register

### LLC\_DATA\_INV\_CTL

This register controls a state machine that can invalidate the contents of data array banks. Each way has a corresponding bit in this register. When the register is written, the invalidation engine will kick off and invalidate the data for each of the specified ways. Writing a value of 1 to a bit indicates that the corresponding way should be invalidated. Writing a value of 0 to a bit indicates that the content of that way shouldn't be invalidated.

The register can be read to determine the current status of the data bank invalidation sequence. When hardware has completed the invalidation sequence for a way, it will change the value of that register bit from 1 to 0. If the entire register has a value of 0, then the invalidation engine has completed. The reset value of this register is zero.

Invalidation of the data array is needed when switching between cache mode and scratchpad RAM mode, since the RAM mode allows direct access to the data. Any secure data that was stored in the cache may be visible to RAM mode accesses unless it is invalidated first. Similarly, if security permissions are removed for the Scratchpad RAM, the prior contents should be invalidated before removing the security check.

An invalidation sequence should be completed before a second sequence is requested.

This register requires secure access, since it invalidates data array, potentially modifying the contents of secure data.

Attribute: RW

Security: Secure access only

Bit field description:

* **Data\_Bank\_Invalidation\_Enable** [31:0] - Data Bank Invalidation Enable

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 63 | 62 | 61 | 60 | 59 | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 | 50 | 49 | 48 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 | 38 | 37 | 36 | 35 | 34 | 33 | 32 |
| u | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Data\_Bank\_Invalidation\_Enable | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |

Table 7 LLC\_DATA\_INV\_CTL register

### LLC\_ECC\_DATA\_ADDR

This is a status register that tracks the address of ECC errors that occur in the Data ram. If only one of either the SB bit or the DB bit is set in the ecc\_data\_info register, this address contains the address for that error. If both the SB and the DB ecc error bits are set in the ecc\_data\_info register, this register contains the address of the DB error.

Attribute: RW

Security: Non secure

Bit field description:

* **Address** [59:0] - Address of first detected error

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 63 | 62 | 61 | 60 | 59 | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 | 50 | 49 | 48 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 | 38 | 37 | 36 | 35 | 34 | 33 | 32 |
| u | | | | Address | | | | | | | | | | | | | | | | | | | | | | | | | | | |
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Address | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |

Table 8 LLC\_ECC\_DATA\_ADDR register

### LLC\_ECC\_DATA\_INFO

This is a status register that tracks ECC errors that occur in the Data array. The register will track the number of ECC errors, as well as whether single-bit or double-bit errors have been detected. If the SB bit is set, at least one single bit error has been detected. If the DB bit is set, at least one double-bit error has been detected.

Additionally, the register tracks information about the first error detected. It stores the index of the tag array that had the error, as well as the way group. It also tracks which half of the cache line failed, which is needed to identify the sub-bank that failed. If a double-bit error occurs after a single-bit error has already been recorded, the double-bit error will overwrite the content of the register. This is because double-bit errors are fatal, and the information about how a fatal error is more important that the information about a non-fatal error.

The register can be read for status, but can also be written. If the SB and DB bit are written with zeros, the sampling of the first detected error will happen as described above.

Attribute: RW

Security: Non secure

Bit field description:

* **Index** [45:32] - index of first detected error
* **ECC\_Count** [31:16] - number of ECC errors found
* **hlf** [9] - Which half of cache line reported error
* **way** [8:2] - Way group of first detected error
* **db** [1] - Detected double or multi bit error
* **sb** [0] - Detected single bit error

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 63 | 62 | 61 | 60 | 59 | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 | 50 | 49 | 48 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 | 38 | 37 | 36 | 35 | 34 | 33 | 32 |
| u | | | | | | | | | | | | | | | | | | Index | | | | | | | | | | | | | |
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| ECC\_Count | | | | | | | | | | | | | | | | u | | | | | | hlf | way | | | | | | | db | sb |

Table 9 LLC\_ECC\_DATA\_INFO register

### LLC\_ECC\_DISABLE

This register allows ECC to be disabled for either the Data arrays or the Tag arrays. These are independently controlled. A bit value of 1 indicates that ECC is disabled. A bit value of 0 indicates ECC is enabled, if present. The register value resets to value 0, meaning ECC is enabled.

Attribute: RW

Security: Non secure

Bit field description:

* **D** [1] - Disable Data ECC Check/Correct
* **T** [0] - Disable Tag ECC Check/Correct

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 63 | 62 | 61 | 60 | 59 | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 | 50 | 49 | 48 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 | 38 | 37 | 36 | 35 | 34 | 33 | 32 |
| u | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| u | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | D | T |

Table 10 LLC\_ECC\_DISABLE register

### LLC\_ECC\_TAG\_ADDR

This is a status register that tracks the address of ECC errors that occur in the Tag ram. If only one of either the SB bit or the DB bit is set in the ecc\_tag\_info register, this address contains the address for that error. If both the SB and the DB ecc error bits are set in the ecc\_tag\_info register, this register contains the address of the DB error.

Attribute: RW

Security: Non secure

Bit field description:

* **Address** [59:0] - Address of first detected error

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 63 | 62 | 61 | 60 | 59 | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 | 50 | 49 | 48 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 | 38 | 37 | 36 | 35 | 34 | 33 | 32 |
| u | | | | Address | | | | | | | | | | | | | | | | | | | | | | | | | | | |
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Address | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |

Table 11 LLC\_ECC\_TAG\_ADDR register

### LLC\_ECC\_TAG\_INFO

This is a status register that tracks ECC errors that occur in the Tag array. The register will track the number of ECC errors, as well as whether single-bit or double-bit errors have been detected. If the SB bit is set, at least one single bit error has been detected. If the DB bit is set, at least one double-bit error has been detected.

Additionally, the register tracks information about the first error detected. It stores the index of the tag array that had the error, as well as the way group. If a double-bit error occurs after a single-bit error has already been recorded, the double-bit error will overwrite the content of the register. This is because double-bit errors are fatal, and the information about how a fatal error is more important that the information about a non-fatal error.

The register can be read for status, but can also be written. If the SB and DB bit are written with zeros, the sampling of the first detected error will happen as described above.

Attribute: RW

Security: Non secure

Bit field description:

* **Index** [45:32] - Index of first detected error
* **ECC\_Count** [31:16] - Number of ECC errors found
* **way** [6:2] - Way group of first detected error
* **db** [1] - Detected double or multi bit error
* **sb** [0] - Detected single bit error

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 63 | 62 | 61 | 60 | 59 | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 | 50 | 49 | 48 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 | 38 | 37 | 36 | 35 | 34 | 33 | 32 |
| u | | | | | | | | | | | | | | | | | | Index | | | | | | | | | | | | | |
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| ECC\_Count | | | | | | | | | | | | | | | | u | | | | | | | | | way | | | | | db | sb |

Table 12 LLC\_ECC\_TAG\_INFO register

### LLC\_EVENT\_COUNTER\_0

This register is the first of two event counters. When its event counter mask control enables certain events to be counted, they will increment this counter. When the counter overflows, in can produce an interrupt if the interrupt mask is enabled. This can be used to trap to software after a number of specified events has occurred.

The counter can be read or written. Writing the value can initialize the counter to a larger value which can speed up the point at which counter will overflow and the interrupt will be triggered.

Attribute: RW

Security: Non secure

Bit field description:

* **Event\_Counter\_Value\_0** [31:0] -

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 63 | 62 | 61 | 60 | 59 | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 | 50 | 49 | 48 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 | 38 | 37 | 36 | 35 | 34 | 33 | 32 |
| u | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Event\_Counter\_Value\_0 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |

Table 13 LLC\_EVENT\_COUNTER\_0 register

### LLC\_EVENT\_COUNTER\_1

This register is the first of two event counters. When its event counter mask control enables certain events to be counted, they will increment this counter. When the counter overflows, in can produce an interrupt if the interrupt mask is enabled. This can be used to trap to software after a number of specified events has occurred.

The counter can be read or written. Writing the value can initialize the counter to a larger value which can speed up the point at which counter will overflow and the interrupt will be triggered.

Attribute: RW

Security: Non secure

Bit field description:

* **Event\_Counter\_Value\_1** [31:0] -

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 63 | 62 | 61 | 60 | 59 | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 | 50 | 49 | 48 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 | 38 | 37 | 36 | 35 | 34 | 33 | 32 |
| u | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Event\_Counter\_Value\_1 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |

Table 14 LLC\_EVENT\_COUNTER\_1 register

### LLC\_EVENT\_COUNTER\_MASK\_0

This register is used to program its corresponding event counter. Each bit of this register enables the performance counter to increment if the event occurs. A value of 1 for a bit indicates that this event should be counted.

If multiple bits are set to 1, the logic will only count if all of the corresponding events occur on the same cycle. This allows for combinations of events, such as a cache miss that causes an eviction. The events that can be counted are all related to cache accesses and occur in the same cycle of the pipeline, so they can be combined easily.

When an event satisfies all of the requirements, the llc\_event\_counter\_0 register will be updated. A value of 1 indicates that the event is selected for counting. A value of 0 the event is not selected. By default, this register will be set to 0 for all bits, indicating no event counting should occur.

Attribute: RW

Security: Non secure

Bit field description:

* **e27** [27] - Allocate conflict
* **e26** [26] - Indx after indx tmp conflict
* **e25** [25] - Wr after alloc conflict
* **e24** [24] - Wr after evict conflict
* **e23** [23] - Rd after rd alloc conflict
* **e22** [22] - Rd alloc after wr conflict
* **e21** [21] - Rd after evict
* **e20** [20] - Tag update
* **e19** [19] - Request CleanUnique
* **e18** [18] - External snoop
* **e17** [17] - Excl wr fails store conditional
* **e16** [16] - Exclusive write
* **e15** [15] - Atomic op
* **e14** [14] - Write through
* **e13** [13] - Rd dealloc on dirty
* **e12** [12] - Rd dealloc
* **e11** [11] - Partial line wr
* **e10** [10] - Fetch due to partial wr
* **e9** [9] - Retry access
* **e8** [8] - Retry needed
* **e7** [7] - Eviction
* **e6** [6] - Cache maint op
* **e5** [5] - Partial write
* **e4** [4] - Cache miss
* **e3** [3] - Cache hit
* **e2** [2] - Scratchpad access
* **e1** [1] - Cache write
* **e0** [0] - Cache read

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 63 | 62 | 61 | 60 | 59 | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 | 50 | 49 | 48 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 | 38 | 37 | 36 | 35 | 34 | 33 | 32 |
| u | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| u | | | | e27 | e26 | e25 | e24 | e23 | e22 | e21 | e20 | e19 | e18 | e17 | e16 | e15 | e14 | e13 | e12 | e11 | e10 | e9 | e8 | e7 | e6 | e5 | e4 | e3 | e2 | e1 | e0 |

Table 15 LLC\_EVENT\_COUNTER\_MASK\_0 register

### LLC\_EVENT\_COUNTER\_MASK\_1

This register is used to program its corresponding event counter. Each bit of this register enables the performance counter to increment if the event occurs. A value of 1 for a bit indicates that this event should be counted.

If multiple bits are set to 1, the logic will only count if all of the corresponding events occur on the same cycle. This allows for combinations of events, such as a cache miss that causes an eviction. The events that can be counted are all related to cache accesses and occur in the same cycle of the pipeline, so they can be combined easily.

When an event satisfies all of the requirements, the llc\_event\_counter\_1 register will be updated. A value of 1 indicates that the event is selected for counting. A value of 0 the event is not selected. By default, this register will be set to 0 for all bits, indicating no event counting should occur.

Attribute: RW

Security: Non secure

Bit field description:

* **e27** [27] - Allocate conflict
* **e26** [26] - Indx after indx tmp conflict
* **e25** [25] - Wr after alloc conflict
* **e24** [24] - Wr after evict conflict
* **e23** [23] - Rd after rd alloc conflict
* **e22** [22] - Rd alloc after wr conflict
* **e21** [21] - Rd after evict
* **e20** [20] - Tag update
* **e19** [19] - Request CleanUnique
* **e18** [18] - External snoop
* **e17** [17] - Excl wr fails store conditional
* **e16** [16] - Exclusive write
* **e15** [15] - Atomic op
* **e14** [14] - Write through
* **e13** [13] - Rd dealloc on dirty
* **e12** [12] - Rd dealloc
* **e11** [11] - Partial line wr
* **e10** [10] - Fetch due to partial wr
* **e9** [9] - Retry access
* **e8** [8] - Retry needed
* **e7** [7] - Eviction
* **e6** [6] - Cache maint op
* **e5** [5] - Partial write
* **e4** [4] - Cache miss
* **e3** [3] - Cache hit
* **e2** [2] - Scratchpad access
* **e1** [1] - Cache write
* **e0** [0] - Cache read

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 63 | 62 | 61 | 60 | 59 | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 | 50 | 49 | 48 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 | 38 | 37 | 36 | 35 | 34 | 33 | 32 |
| u | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| u | | | | e27 | e26 | e25 | e24 | e23 | e22 | e21 | e20 | e19 | e18 | e17 | e16 | e15 | e14 | e13 | e12 | e11 | e10 | e9 | e8 | e7 | e6 | e5 | e4 | e3 | e2 | e1 | e0 |

Table 16 LLC\_EVENT\_COUNTER\_MASK\_1 register

### LLC\_FORCE\_PARTIAL\_WR\_ALLOC

This register holds one bit for each of the LLC Allocation Classes. When set to 0, all partial write misses will follow normal write allocation rules (llc\_alloc\_wr\_en or awcache). When set to 1, all partial write misses will be forced to allocate (fetch first followed by merge). All partial write hits will be merged into the cache regardless of the configuration.

Attribute: RW

Security: Non secure

Bit field description:

* **Force\_Partial\_Write\_Allocation** [7:0] - Force\_Partial\_Write\_Allocation

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 63 | 62 | 61 | 60 | 59 | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 | 50 | 49 | 48 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 | 38 | 37 | 36 | 35 | 34 | 33 | 32 |
| u | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| u | | | | | | | | | | | | | | | | | | | | | | | | Force\_Partial\_Write\_Allocation | | | | | | | |

Table 17 LLC\_FORCE\_PARTIAL\_WR\_ALLOC register

### LLC\_GLOBAL\_ALLOC

This register controls whether lines can be allocated into a way by any agent.

If a way is disabled from allocation in this register, no agents can allocate even if the llc\_class\_allocate registers are set. This register is used as part of a sequence to remove ways from use by the cache for either Scratchpad RAM usage, or for power gating. By removing allocation ability, a flush engine can remove the existing contents of the line without fear that new entries will be added during or after the flush.

The default value of this register enables allocation for all ways of the cache, and so each bit corresponding to a way is set to 1. To disable allocation, the bits should be set to 0.

Attribute: RW

Security: Non secure

Bit field description:

* **Global\_Allocation\_Way\_Enable** [31:0] - Global Allocation Way Enable

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 63 | 62 | 61 | 60 | 59 | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 | 50 | 49 | 48 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 | 38 | 37 | 36 | 35 | 34 | 33 | 32 |
| u | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Global\_Allocation\_Way\_Enable | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |

Table 18 LLC\_GLOBAL\_ALLOC register

### LLC\_INDIRECT\_RAM\_CONT

This is the indirect access RAM content register. It is used in conjunction with the indirect access trigger register. On an indirect read, data is written to this register. On an indirect write, content from this register is written into the RAM. On a read-modify-write, content from this register is used for the XOR function.

Since the RAM data width may be larger than 64 bits, multiple registers are used to hold the data. Any bits beyond the data width are unused.

This register requires secure access, since it can be used to modify or observe the contents of data.

Attribute: RW

Security: Secure access only

Bit field description:

* **RAM\_content** [63:0] -

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 63 | 62 | 61 | 60 | 59 | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 | 50 | 49 | 48 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 | 38 | 37 | 36 | 35 | 34 | 33 | 32 |
| RAM\_content | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| RAM\_content | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |

Table 19 LLC\_INDIRECT\_RAM\_CONT register

### LLC\_INDIRECT\_TRIGGER

This register is the indirect access trigger. Indirect access is a mechanism that allows register-based access to the RAM arrays. This can be used for testing RAM bits or reading content on an error condition.

The indirect access is based on a content+trigger mechanism. For writes, the content register is written first to accumulate the data that should be written. Once the content is ready, the trigger register is used to kick off the hardware write mechanism. For reads, the trigger register kicks off a read, and provides data by placing the result into the content registers where it can be accessed.

The indirect access supports 4 sub-commands.

1. Read Raw data. When triggered, a read to the RAM array will be performed and the resulting data, without ECC correction, will be copied into the content register.
2. Write Raw Data. When triggered, the content register values will be written into the RAM. This will include the ECC bits if present.
3. Write Data with Generated ECC. When triggered, this will write to the RAM entry. The content register will be used to specify the data to be written. However, if ECC hardware is present, the ECC bits will be generated based on the data instead of coming from the content register. This allows the RAM entry to be written with correct ECC value without needing to calculate it first.
4. Read-Modify-Write. This command will perform a specific kind of read-modify-write operation on a RAM entry. It will read the content of the RAM, XOR that content with the indirect content register, and write the combined value into the same RAM entry. This can be used to introduce single or double bit errors into the directory to test error detection and handling. The content register will not be modified during this operation, so it can be used to introduce errors into multiple lines.

Each of the indirect access commands can be issued during normal operation, but the Write commands can have side-effects that break coherency functionality. The Read Raw is not disruptive, and the Read-Modify-Write can be performed atomically so single-bit errors can be introduced while maintaining functionality. The indirect access trigger registers are readable and writeable. To trigger the RAM access, this register must be written. Reads will not have side-effects and will only return the current value of the trigger register.

The trigger register has a number of fields that must be set correctly. The CMD field indicates which kind of indirect access to perform. The WAY field indicates which way group to access. The TYP field indicates whether the Data array or Tag array should be accessed. If the Data array is accessed, the hlf bit indicates which sub-bank is accessed. The RAM index indicates the entry to access within the RAM.

This register requires secure access, since it can be used to modify or observe the contents of data.

Attribute: RW

Security: Secure access only

Bit field description:

* **Index** [31:11] - Index of RAM to access
* **way** [10:9] - Way position in the waygroup
* **hlf** [8] - Which half of cache line reported error
* **waygroup** [7:3] - Way group of first detected error
* **typ** [2] -   
  0: Tag array access  
  1: Data array access
* **cmd** [1:0] -   
  00: Read raw array content including any ECC bits and copy to RAM Content register  
  01: Write RAM content register directly into array  
  10: Write RAM content minus ECC bits to array, use ECC generation logic to set ECC bits in array  
  11: Read-modify-write. Read array content, XOR with RAM content register, and write modified data into array

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 63 | 62 | 61 | 60 | 59 | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 | 50 | 49 | 48 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 | 38 | 37 | 36 | 35 | 34 | 33 | 32 |
| u | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Index | | | | | | | | | | | | | | | | | | | | | way | | hlf | waygroup | | | | | typ | cmd | |

Table 20 LLC\_INDIRECT\_TRIGGER register

### LLC\_INTERRUPT\_ERR

This is a status register that tracks the interrupt generating events. This includes multi-bit ECC error, single-bit ECC error, RAM mode disallowed accesses, and event counter overflow. When these events occur, this register is updated and will hold the bit value until cleared. It can be cleared by writing to the register. To allow per-bit clearing control, the write value should use a value of 1 when it doesn't want to make a change, or a bit value of 0 when it wants to clear.

Attribute: WZC

Security: Non secure

Bit field description:

* **e8** [8] - Data Parity Error
* **e7** [7] - Register Parity Error
* **e6** [6] - Event Counter Overflow
* **e5** [5] - Scratchpad Security Failure status
* **e4** [4] - Scratchpad RAM Disabled status
* **e3** [3] - Data ECC Double Bit Error status
* **e2** [2] - Data ECC Single Bit Error status
* **e1** [1] - Tag ECC Double Bit Error status
* **e0** [0] - Tag ECC Single Bit Error status

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 63 | 62 | 61 | 60 | 59 | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 | 50 | 49 | 48 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 | 38 | 37 | 36 | 35 | 34 | 33 | 32 |
| u | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| u | | | | | | | | | | | | | | | | | | | | | | | e8 | e7 | e6 | e5 | e4 | e3 | e2 | e1 | e0 |

Table 21 LLC\_INTERRUPT\_ERR register

### LLC\_INTERRUPT\_FATAL\_MASK

This register determines which errors in llc\_interrupt\_err should be considered fatal. 1 is fatal and 0 is non-fatal.

Attribute: RW

Security: Non secure

Bit field description:

* **e8** [8] - Data Parity Error
* **e7** [7] - Register Parity Error
* **e6** [6] - Event Counter Overflow
* **e5** [5] - Scratchpad Security Failure status
* **e4** [4] - Scratchpad RAM Disabled status
* **e3** [3] - Data ECC Double Bit Error status
* **e2** [2] - Data ECC Single Bit Error status
* **e1** [1] - Tag ECC Double Bit Error status
* **e0** [0] - Tag ECC Single Bit Error status

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 63 | 62 | 61 | 60 | 59 | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 | 50 | 49 | 48 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 | 38 | 37 | 36 | 35 | 34 | 33 | 32 |
| u | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| u | | | | | | | | | | | | | | | | | | | | | | | e8 | e7 | e6 | e5 | e4 | e3 | e2 | e1 | e0 |

Table 22 LLC\_INTERRUPT\_FATAL\_MASK register

### LLC\_INTERRUPT\_MASK

This register is used for determining what kind of events can trigger an interrupt from the LLC.

A bit value of 1 indicates that the event will not send an interrupt. A bit value of 0 means the event will cause an interrupt. The default values are listed in the bit field description.

Attribute: RW

Security: Non secure

Bit field description:

* **m8** [8] -   
  1'b1: Data parity error interrupt disabled.  
  1'b0: Data parity error interrupt enabled (default).
* **m7** [7] -   
  1'b1: Register parity error interrupt disabled.  
  1'b0: Register parity error interrupt enabled (default).
* **m6** [6] -   
  1'b1: Event Counter Overflow interrupt disabled (default).  
  1'b0: Event Counter Overflow interrupt enabled.
* **m5** [5] -   
  1'b1: Scratchpad Security Check Failure interrupt disabled.  
  1'b0: Scratchpad Security Check Failure interrupt enabled (default).
* **m4** [4] -   
  1'b1: Scratchpad RAM Access while Disabled interrupt disabled.  
  1'b0: Scratchpad RAM Access while Disabled interrupt enabled (default).
* **m3** [3] -   
  1'b1: Data ECC Double Bit Error interrupt disabled.  
  1'b0: Data ECC Double Bit Error interrupt enabled (default).
* **m2** [2] -   
  1'b1: Data ECC Single Bit Error interrupt disabled (default).  
  1'b0: Data ECC Single Bit Error interrupt enabled.
* **m1** [1] -   
  1'b1: Tag ECC Double Bit Error interrupt disabled.  
  1'b0: Tag ECC Double Bit Error interrupt enabled (default).
* **m0** [0] -   
  1'b1: Tag ECC Single Bit Error interrupt disabled (default).  
  1'b0: Tag ECC Single Bit Error interrupt enabled.

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 63 | 62 | 61 | 60 | 59 | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 | 50 | 49 | 48 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 | 38 | 37 | 36 | 35 | 34 | 33 | 32 |
| u | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| u | | | | | | | | | | | | | | | | | | | | | | | m8 | m7 | m6 | m5 | m4 | m3 | m2 | m1 | m0 |

Table 23 LLC\_INTERRUPT\_MASK register

### LLC\_OPERATION\_CONTROL

This register is used to change the behavior of the LLC in various ways, as listed in the description for each bit. The default values are listed in the bit field description.

Attribute: RW

Security: Non secure

Bit field description:

* **FAS** [1] -   
  1'b1: Force address serialization--only 1 operation can issue to memory for an address.   
  1'b0: Do not force address serialization. Default value.
* **LRU** [0] -   
  1'b1: Enable LRU updates on a cache hit.  
  1'b0: Disable LRU updates on a cache hit.

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 63 | 62 | 61 | 60 | 59 | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 | 50 | 49 | 48 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 | 38 | 37 | 36 | 35 | 34 | 33 | 32 |
| u | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| u | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | FAS | LRU |

Table 24 LLC\_OPERATION\_CONTROL register

### LLC\_RAM\_ADDRESS\_BASE

This register indicates the system address offset of the RAM mode. The address range should always be allocated as the full size of the LLC capacity rounded up to a power of 2, and the address offset must be programmed to a naturally aligned address for that size. The default value of this register is the address range base specified during NoC construction.

This register requires secure access, since it controls the address range for RAM storage, implicitly changing the contents of that range.

Attribute: RW

Security: Secure access only

Bit field description:

* **Address**[63:0] - Address

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 63 | 62 | 61 | 60 | 59 | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 | 50 | 49 | 48 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 | 38 | 37 | 36 | 35 | 34 | 33 | 32 |
| Address | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Address | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |

Table 25 LLC\_RAM\_ADDRESS\_BASE register.

### LLC\_RAM\_WAY\_ENABLE

This register is used to enable cache ways to be used as a Scratchpad RAM instead of a cache. The register indicates which of the ways should be used as a RAM instead of a cache. It is possible to use some of the LLC as a cache, and some as a RAM, by selecting which ways are used by each. By default, this register is set to 0 so that all ways are used as cache. To set this register, the lines must be removed from cache usage by the llc\_cache\_way\_enable register. Any cache contents should be flushed before enabling the RAM mode.

This register requires secure access, since it enables RAM storage, allowing previous content of the cache to be visible to scratchpad reads.

Attribute: RW

Security: Secure access only

Bit field description:

* **Scratchpad\_Ram\_Way\_Group\_Enable**[31:0] - Scratchpad Ram Way Enable

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 63 | 62 | 61 | 60 | 59 | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 | 50 | 49 | 48 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 | 38 | 37 | 36 | 35 | 34 | 33 | 32 |
| u | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Scratchpad\_Ram\_Way\_Group\_Enable | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |

Table 26 LLC\_RAM\_WAY\_ENABLE register

### LLC\_RAM\_WAY\_SECURE

This register allows the Scratchpad RAM to have trust-zone security checking. Each way can be individually controlled. If the security bit is set, only secure accesses (those with AxPROT [1] set to secure) can access that address. Non-secure accesses will be responded to with an error, and an interrupt will be triggered if the interrupt is enabled.

A value of 1 indicates secure accesses are required, while a value of 0 indicates no security check is needed (secure or non-secure accesses are enabled). By default, this register is 0, so no security checking occurs.

This register requires secure access, since it controls the security check for scratchpad RAM storage.

Attribute: RW

Security: Secure access only

Bit field description:

* **Scratchpad\_Ram\_Way\_Group\_Security**[31:0] - Scratchpad Ram Way Security

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 63 | 62 | 61 | 60 | 59 | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 | 50 | 49 | 48 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 | 38 | 37 | 36 | 35 | 34 | 33 | 32 |
| u | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Scratchpad\_Ram\_Way\_Group\_Security | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |

Table 27 LLC\_RAM\_WAY\_SECURE register

### LLC\_READ\_DEALLOCATE

This register holds one bit for each of the LLC Allocation Classes. When set to 1, the read hits for the LLC class will result in the cacheline being invalidated. Dirty cachelines will either be discarded or flushed depending on the setting in the LLC\_READ\_DISCARD\_DIRTY register. When set to 0, normal cache read behavior will apply.

Attribute: RW

Security: Non secure

Bit field description:

* **LLC\_READ\_DEALLOCATE** [7:0] - Per Allocation Class Read-And-Invalidate Enable

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 63 | 62 | 61 | 60 | 59 | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 | 50 | 49 | 48 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 | 38 | 37 | 36 | 35 | 34 | 33 | 32 |
| u | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| u | | | | | | | | | | | | | | | | | | | | | | | | LLC\_READ\_DEALLOCATE | | | | | | | |

Table 28 LLC\_READ\_DEALLOCATE register

### LLC\_READ\_DISCARD\_DIRTY

This register holds one bit for each of the LLC Allocation Classes. When set to 1, and the corresponding bit (class) in LLC\_READ\_DEALLOCATE is also set to 1, read hits on a dirty line will be discarded without write back.

Attribute: RW

Security: Non secure

Bit field description:

* **LLC\_READ\_DISCARD\_DIRTY**[7:0] - Per Allocation Class Control For Dirty Line When Read-And-Invalidate (Read Deallocate)

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 63 | 62 | 61 | 60 | 59 | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 | 50 | 49 | 48 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 | 38 | 37 | 36 | 35 | 34 | 33 | 32 |
| u | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| u | | | | | | | | | | | | | | | | | | | | | | | | LLC\_READ\_DISCARD\_DIRTY | | | | | | | |

Table 29 LLC\_READ\_DISCARD\_DIRTY register

### LLC\_SHDW\_PIPE\_STATUS

This register reports incoming request activity and resource availability for fulfilling those requests. Insight into pipeline stalls may be gleaned by polling this register and looking for chronically active request sources that do not have resource availability.

Attribute: R

Security: Non secure

Bit field description:

* **QREQS** [41:32] - Vector showing qualified request status to the LLC from various sources. These are active requests qualified by resource availability. Only when all required resources for a particular request source are 1 will the filtered request status be 1 (if the unfiltered request status is 1).

[9] evt  
 [8] extsnp  
 [7] tagupdate  
 [6] flush\_req  
 [5] rd\_sprt1  
 [4] rd\_sprt0  
 [3] retry\_rd  
 [2] wr\_sprt1  
 [1] wr\_sprt0  
 [0] retry\_wr

* **REQS** [25:16] - Vector showing request status to the LLC from various sources.

[9] evt  
 [8] extsnp  
 [7] tagupdate  
 [6] flush\_req  
 [5] rd\_sprt1  
 [4] rd\_sprt0  
 [3] retry\_rd  
 [2] wr\_sprt1  
 [1] wr\_sprt0  
 [0] retry\_wr

* **PS** [14] - TAC pipeline stall signal status. All incoming requests to lookup arbiter are held off while this signal is active, regardless of resource availability.
* **RSRCS** [13:0] - Vector showing the availability status of the various resources of the LLC.

[13] acem\_ar  
 [12] chim\_ar  
 [11] chim\_aww  
 [10] mprt\_aww  
  [9] mprt\_ar  
  [8] missq\_wr  
  [7] missq\_rd  
  [6] dac\_cmd  
  [5] dac\_wctl  
  [4] tac  
  [3] retry  
  [2] wrsp  
  [1] evict  
  [0] atomics

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 63 | 62 | 61 | 60 | 59 | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 | 50 | 49 | 48 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 | 38 | 37 | 36 | 35 | 34 | 33 | 32 |
| u | | | | | | | | | | | | | | | | | | | | | | QREQS | | | | | | | | | |
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| u | | | | | | REQS | | | | | | | | | | u | PS | RSRCS | | | | | | | | | | | | | |

Table 30 LLC\_SHDW\_PIPE\_STATUS register

### LLC\_SPARE

This register contains writable spare bits. Software may read and write these bits. They retain any value written to them (between reset events), but otherwise they have no functional effect.

Attribute: RW

Security: Non secure

Bit field description:

* **BITS** [31:0] - Spare Bits

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 63 | 62 | 61 | 60 | 59 | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 | 50 | 49 | 48 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 | 38 | 37 | 36 | 35 | 34 | 33 | 32 |
| u | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| BITS | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |

Table 31 LLC\_SPARE register

### LLC\_TAG\_INV\_CTL

The Tag Invalidation Control register triggers a state machine that will invalidate the contents of one or more way groups of the cache. The register has one bit per way group, and the bit vector written into this register will invalidate the corresponding way groups. A value of 1 will indicate that the corresponding way group should be invalidated. A value of 0 will indicate that the way group should not be invalidated. This per-way group control allows portions of the cache to be powered down and restarted later, with the ability to reset just the way groups that were powered down and powered back on.

A write to the register will kick off the invalidation engine, invalidating the specified way groups. A read of the register will indicate whether the invalidation is in progress. When the invalidation engine has completed, the bit vector will transition to a value of zero. So a read value of zero will indicate that the state machine has completed. The reset value of this register is zero. An invalidation sequence should be completed before a second sequence is requested.

This register requires secure access, since it invalidates tags, potentially modifying the contents of secure data.

Attribute: RW

Security: Secure access only

Bit field description:

* **Tag\_Way\_Group\_Invalidation\_Enable** [31:0] - Tag Way Group Invalidation Enable

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 63 | 62 | 61 | 60 | 59 | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 | 50 | 49 | 48 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 | 38 | 37 | 36 | 35 | 34 | 33 | 32 |
| u | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Tag\_Way\_Group\_Invalidation\_Enable | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |

Table 32 LLC\_TAG\_INV\_CTL register

### LLC\_WAY\_FLUSH

This register controls a state machine that flushes specified ways of the cache. The intent of this engine is to remove all content from the specified ways, pushing any dirty data that may exist to memory. It also invalidates clean lines. The Way Flush engine should be run while the llc\_cache\_way\_enable is still on for those ways so the contents are still accessible, but the llc\_global\_alloc register should have disabled the way for allocation. This ensures that as lines are removed from the cache, they won't unintentionally get added again. Clean lines are invalidated to ensure that dirty line writes do not write into the ways being flushed.

Writing the register will kick off the flush engine. If the write value specifies a bit value of 1, then that way group will be flushed. If the bit value written is zero, that way will not be flushed. When the sequence is completed, hardware will transition the bit values to zero. A register value of 0 indicates the state machine has complete. The default value for this register is zero.

A flush sequence should be completed before a second sequence is requested.

This register requires secure access, since it flushes cache lines.

Attribute: RW

Security: Secure access only

Bit field description:

* **Way\_Flush\_Control** [31:0] - Way Flush Control

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 63 | 62 | 61 | 60 | 59 | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 | 50 | 49 | 48 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 | 38 | 37 | 36 | 35 | 34 | 33 | 32 |
| u | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Way\_Flush\_Control | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |

Table 33 LLC\_WAY\_FLUSH register

### LLC\_WRITETHROUGH\_EN

This register holds one bit for each of the LLC Allocation Classes. When set to 1, the write accesses that allocate will be write-through. When set to 0, write accesses will be write-back.

Attribute: RW

Security: Non secure

Bit field description:

* **LLC\_WRITETHROUGH\_EN** [7:0] - Write should be write-through

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 63 | 62 | 61 | 60 | 59 | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 | 50 | 49 | 48 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 | 38 | 37 | 36 | 35 | 34 | 33 | 32 |
| u | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| u | | | | | | | | | | | | | | | | | | | | | | | | LLC\_WRITETHROUGH\_EN | | | | | | | |

Table 34 LLC\_WRITETHROUGH\_EN register